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(54) Method for extracting a tliree-dimensional model from a sequence of images 



(57) In a computerized method, a three-dimensional 
model is extracted from a sequence of images that 
includes a reference image. Each image in the 
sequence is registered with the reference image to 
determine image features. The image features are used 
to recover structure and motion parameters using geo- 
metric constraints in the form of a wireframe mode. A 
predicted appearance is generated for each image 
using the recovered structure and motion parameters, 
and each predicted appearance is registered with the 
corresponding image. The recovering, generating, and 
registering steps are repeated until the average pixel 
value difference (color or intensity) between the pre- 
dicted appearances and the corresponding images is 
less than a predetermined threshold. 
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Description 

Reld Of The invention 

s [0001 1 This invention relates generaliy to computer vision, and more particularly to recovering structure from motion 
as expressed by optical flow in a sequence of images. 

Background Of The invention 

10 [00021 In computer vision, one problem is to recover the three-dimensional configuration of an object from a sequence 
of two-dimensional images acquired by a camera. This is especially difficult when both the camera parameters and 
point correspondences across the image sequence are unknown. . ^, .^.,«v,=c«Hna 

[00031 There is a large body of work on the recovery of raw 3-D data from multiple images; they include mu tibasehne 
stereo, trinocular stereo that combines constant brightness constraint with trilinear tensor, stereo with interpolation, and 

(5 shape from rotation. 

[00041 Virtually all stereo approaches assume a fixed disparity throughout once the disparity has been established, 
e a through a separate feature tracker or image registration technique. Most techniques assume that the camera 
parameters, intrinsic and extrinsic, are known. For 3-D facial modeling, the following techniques are generally known. 

so From range data: 

[00051 Range acquisition equipment includes light-stripe rangefinders. and laser rangef inders. Rangef inders. when 
compared to video cameras, are relatively expensive, and considerable post-processing is still required^For example in 
one method, feature-based matching for facial features, such as the nose, chin, ears, eyes, are applied to dense 3-D 
25 data to initialize an adaptable facial mesh. Subsequently, a dynamic model of facial tissue controlled by fa«al muscl^ 
is generated. In another method, a range image with a corresponding color image of a face is used. The 2-D color 
image is used to locate eyes, eyebrows, and mouth. Edges in color space are determined, and contour smoothing is 
achieved by dilation and shrinking. 

30 From two 2-D images: 

(00061 Two orthogonal views of a face are normally used. The profiles are extracted and analyzed; this is followed by 
facial feature extraction. A 3-D face template is then adjusted by interpolation, based on the extracted information. 

35 From a sequence of temporally related 2-D images: 

[0007] In one approach, 2-D images are used to reconstruct both shape and reflectance properties of surfaces from 
multiple images. The surface shape is initialized by conventional stereo image processing. An objective functton uses 
the weighted sum of stereo, shading, and smoothness constraints The combination of weights depends on local tex- 

40 ture. favoring stereo for high texture with a known light source direction and known camera parameters. 

[0008] A calibrated stereo pair of images has also been used. There, a disparity map is determined, followed by inter- 
polation. In one implementation, three-dimensional deformation is guided by differential features that have high curva- 
ture values, for example, the nose, and eye orbits. If the motion between images in a sequence is small, then the optica^ 
flow can be used to move and deform a face model to track facial expressions. Rxed point correspondences defined 

4S by the optical flow The deformation of the face model is constrained and specific to faces. Facial anthropometric data 
are used to limit facial model deformations in initialization and during tracking with the camera's focal length approxi- 

ra009] ""l^dfferent approach, facial features such as the eyes, nose and mouth are tracked using recursive Kalman 
f iltering to estimate structure and motion. The filter output is used to deform the shape of the face subject to predefined 
so constraints specified by a linear subspace of eigenvectors. 

SUIVIMARY OF THE INVENTION 

[001 01 Provided is a computerized method for recovering 3-D models from a sequence of uncalibrated images with 
55 unknown point correspondences. To that end. tracking, structure from motion with geometric constramts. and use o 
deformable 3-D models are integrated in a single framework. The key to making the recovery method is the use of 
appearance-based model matching and refinement. k 
[001 1 1 This appearance-based structure from motion approach is especially useful in recovering shapes of objects 
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whose general structure is known but which may have little discernable texture in significant parts of their surfaces. 
[0012] The invention, in its broad form, resides in a conputerized method for extracting a three-dimensional configu- 
ration of an object from two-dimensional images, as recited in daim 1 , 

[0013] The method can be applied to 3-D face modeling from multiple images to create new 3-D faces for a synthetic 
5 talking head. The talking head includes a collection of 3-D triangular facets, with nodes as vertices. The model can be 
recovered even when the sequence of images are taken with a camera with unknown camera focal length and extrinsic 
parameters, i.e.. the camera pose is unknown. 

[0014] In the general method, a three-dimensional configuration is extracted from a sequence of images including a 
reference image. Each image in the sequence is registered with the reference image to determine image features. The 
10 image features, are used to recover structure and motion parameters using geometric constraints on a 3D wireframe 
mesh template. 

[0015] A predicted appearance is generated for each image using the recovered structure and motion parameters, 
and each predicted appearance is then registered with the corresponding image. The structure and motion recovery, 
appearance generation, and image registration steps are repeated until a selected termination condition is reached, for 
15 example, an average difference between the predicted appearances and the corresponding images is less than a pre- 
determined threshold, or a fixed number of iterations has been performed. 

BRIEF DESCRIPTION OF THE DRAWINGS 

20 [0016] A more detailed understanding of the invention may be had from the following description of a preferred 
embodiment, given by way of example, and to be understood with reference to the accompanying drawing wherein: 

♦ Figure 1 is a block diagram of a 3-D structure recovery system that uses the invention; 

25 ♦ Rgure 2 is a flow diagram of a recovery method according to a preferred embodiment of the invention; 

♦ Rgure 3 is a diagram of spline control grid superimposed on pixel locations: and 

♦ Figure 4 is shows a facial wireframe model superimposed on an image of a face, 

30 

DETAILED DESCRIPTION OF PREFERRED EMBODIMENTS 
Introduction 

35 [001 7] Described is a computerized method for recovering 3-D models from a sequence of uncalibrated images with 
unknown point correspondences. In order to perform the recovery, the difficult point correspondence and occlusion 
problems must be overcome. To that end. tracking, structure from motion with geometric constraints, and use of deform- 
able 3-0 models are integrated in a single framework. The key which makes the method work is the use of appearance- 
based model matching and refinement. 

40 [0018] This appearance-based structure from motion approach Is especially useful in recovering shapes of objects 
whose general structure is known but which may have little discernable texture in significant parts of their surfaces. A 
good example of such an object is the human face, where there is usually a significant amount of relatively untextured 
regions, especially when there is little facial hair, and where the general facial structure is known. Also described below 
is an application of the method to 3-D face modeling from multiple images to generate a 3-D synthetic talking head. 

45 [0019] The talking head model comprises a collection of 3-D triangular facets, with nodes as vertices. The recovery 
is performed from a sequence of images taken with a camera having mostly unknown intrinsic and extrinsic parameters. 
[0020] In one embodiment, a frontal image of the head. i.e.. the face, is used as a reference image. Line-of-sight con- 
straints of 3-D facial nodes are imposed using the reference image. The 3-D model deformation is constrained by min- 
imizing an objective function that trades-off minimal change in local curvature and node position with fit to predicted 

50 point correspondences and face appearance. 

[0021 ] For general camera motion with constant intrinsic parameters, three views are theoretically sufficient to recover 
structure, camera motion, and all five camera intrinsic parameters. For stability reasons, only one unknown intrinsic 
camera parameter is assumed, namely the focal length. The aspect ratio is assumed to be unity, the image skew to be 
insignificant, and the principal point to be coincident with the center of the image. 

55 

System Overview 

[0022] Figure 1 shows an arrangement 100 including a camera 1 10. an image processing system 120, and a monitor 
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130. The camera 110 can acquire a sequence of digital images 203-205 to be processed by the system 120. The 
sequence of Images 203-205 can include various poses of an object, for example, a head 10. Although two images 
should be sufficient to perform some type of 3-D recovery, it is suggested that a minimum of three images are used 
when the shape to be recovered is a face. The poses measured by the camera 1 10 produce a reference frontal image. 
5 and left and right oblique views. An alternate arrangement is to have multiple cameras at predefined locations, each tak- 
ing a snapshot of the same face from a different angle. 

[0023] The system 1 20 can be a conventional computer system or workstation including Input and output devices, for 
example, a mouse 121 and a keyboard 122. The system 120 includes one or more processors (P) 125. memories (M) 
126. and input/output (I/O) 127 interfaces connected by a bus 128. The memories 126 store data and instructions that 
10 operate on the data. The data can be the digital images 203-205 off the sequence, or "frames" acquired by the camera 
1 10. The system 120 can also be connected to a bulk storage device, for exanrple. a disk 123. 



General Operation 

75 [0024] During operation, the system 1 20 uses an appearance-based structure from motion technique to recover a 3- 
D model from Initially unknown point correspondences in the images, and an approximate 3-D template. The model can 
be displayed on the monitor 130. The template can be a "wire-frame mesh templates" having a plurality of polygons, 
described in detail below. 

[0025] Figure 2 shows a flow diagram of a general method 200 for recovering a 3-D structure according to an embod- 
so iment of the invention. The method 200 has an initialization phase 201 . and a refinement loop 202. Image registration 
210 is performed on images 203-205, Each image 204-205 is registered with a reference image 203. In the preferred 
embodiment, the image registration is spline-based as described in U.S. Patent 5.611.00 issued to Szeliski on March 
11 1 997. 

[0026] In step 220. structure motion and parameters are estimated using an iterative Levenberg-Marquardt batch 
25 approach. The appearance prediction is done using simple texture resampling. The predicted appearances 214-215 
corresponding to each of the images 204-205 are based on current image point correspondences and structure from 
motion estimates. The predicted appearances can then be used to refine the image registration during the loop 202. 
[0027] With the appearance-based structure from motion method according to the invention, initialization is first done 
by performing pair-wise spline-based image registration between the reference image and every other image in the 
30 sequence. In other words, the sequence of images 203-205 acquired by the camera 1 10 includes at least two images. 
Better results can be obtained with a sequence of a greater number of images. 

[0028] The registration establishes a set of gross point correspondences for the image sequence. The camera param- 
eters and model shape are extracted from the point correspondences. Subsequently, the method iterates over the fol- 
lowing three major steps in the loop 202: 



35 



Appearance prediction 



[0029] In this step, for each image 204-205 other than the reference image, the appearance as constrained by the 3- 
D model 221. given the camera pose and intrinsic parameters, is determined and projected onto a new image (214- 
40 215). i.e.. predicted appearances. 



Spline-based image registration 

[0030] In step 21 1 . each of the predicted appearances 214-215 is registered with the actual corresponding images 
45 204-205 to refine the point correspondences. Here, the loop 202 can terminate when a predetermined termination con- 
dition is reached, for example, a fixed number of iterations, or the average difference between the images 204-205 and 
the predicted appearances 214-215 is less than some threshold. 

Structure from motion 

so 

[0031] Using the refined point correspondences, estimate the new. and usually better estimates of the camera pose 
and Intrinsic parameters, as well as the 3-D model shape. 

[0032] The use of appearance-based strategy is important because it accounts not only for occlusions, but also per- 
spective distortion due to changes in the pose of the object being imaged. In contrast to prior art techniques which use 
55 edges, or specific object features, e.g.. the eyes. nose, and mouth, the entire predicted images are used here. 
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Tracking by spline-based registration 

[0033] In the preferred spline-based registration framework, each new image Ig (204-205) is registered to an initial 
reference image h (203) using a sum of squared differences formulation (1): 



where the v)'s are estimates of optical flow on a per-pixel basis (X;> yy). 

[0034] In Figure 3. spline control vertices (uy, vy) are shown as circles (o) 310. and the pixel displacements (u/, vi) 
are shown as pluses (+) 320. In the preferred registration technique, the flow estimates (i/;> vi) are represented using 
two-dimensional splines that are controlled by a smaller number of displacement estimates Uj and Vj which lie on a 
coarse spline control grid 330. This is in contrast to representing displacements as completely independent quantities 
having an underconstrained problem. The value for the displacement at a pixel / can be written as (2): 




or 



where the S^/x y) are called the basis functions having non-zero over a small interval, i.e.. there is finite support. The 
= Syi^Xy, / are called weights to emphasize that the displacements (Uf, are known linear combinations of the 
control vertices (^Uy. \>y;. 

[0035] In the preferred implementation, the spline control grid 330 is a regular subsampting of the pixel grid, e.g., 
Xy =mx^ , and y j = my, . Thus, each set of m x m pixels corresponds to a single spline patch 340. The bilinear basis 
functions for the spline can be ^pressed as: 

Bj(x, y) = max ((1- /x - Xjl/m) (Ujy - y ^l/m). 0). 

[0036] Other bases are possible. The local spline-based optica! flow parameters are recovered using a variant of the 
Levenberg-Marquardt iterative non-linear minimization technique. 

[0037] The spline-based equation (2) is modified to include the weights /n^y associated with a mask as follows (3): 



where = 7 or 0 depending on whether the corresponding pixel is in the object or background area respectively. This 
is necessary to prevent registration of the background areas influencing registration of the projected model areas 
across images. The value m^^ can also be between 0 and 1. especially during a hierarchical search where the images 
are subsampled and the intensities are averaged. 

General Structure from Motion 

[0038] The step 220 of recovering structure essentially involves trying to recover a set of 3-D structure parameters P/ 
and time-varying motion parameters Tj from a set of observed image features u,y. The general equation linking a 2-D 
image feature location ty,y in frame j to its 3-D position py, is (4): 
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where / is the track index, and the perspective projection transformation PQ is applied to a cascaded series of rigid 
transformation Tj^^K Each transformation is in turn defined by (5): 

where fl^"^ Is a rotation matrix and is a translation applied after the rotation. Within each of the cascaded time-var- 
ying when the y subscript are present, and fixed when the y subscript is dropped. 
TO [0039] The general camera-centered perspective projection equation is (6) : 
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where f is a product of the focal length of the camera and the pixel array scale factor, r ,s the '"^^ae aspert rata a is 
The ir^age ske^and (un. vo) is the principal point, i.e.. the point where the optical axis of the camera 1 10 '"terseirts the 
XTSanVTn theory^^ camera motion with constant intrinsic parameters, three views are su«.c.ent to 

;3er Structure c^a^^^ motion, and all fK.e camera intrinsic parameters. For sillily, only one intrinsic camera 
parameters matter is considered, namely the focal length, the aspect ratio is assumed to be unity. 
[0040] An alternative object-centered formulation can be expressed as (7): 



0" 



f sx \ 



rsy 



^i-^nxJ 



with a reasonable assumption that a = 0 and (uc vo) = (0. 0). Here, it is assumed that the (x. y,z) coordinates before 
p dertionTre with respert to a reference frame that has been displaced away from the camera by ^ ^ ^t^^® 
Sle optical axis, with s^/f, and n = t/f,. it is possible to consider as the z component of the original global translation 
which is absorbed into the projection equation, and then set the third component of f to zero. 
35 rawil The projection parameter s can be interpreted as a scale factor and n as a P^^Pective distortion facU^TI^^^ 
alt^nLvroerspStive formulation (7) results in a more robust recovery of camera parameters under weak perspective^ 
^feTe > r TndtLm^^ (uo, J'(0. 0) and a » 0. and P(x. y. z/» (sx rsyf ™s is because ^^^^^ .can be much 
more reliably recovered than n. in comparison with formulation (6) where ^ and are highly correlated. 

40 Least-squares l«lnimizatlon with Geometric Constraints 

(0042] The Levenberg-Marquardt algorithm is used to solve tor the structure and motion parameters. However, with 
geometric constraints the method minimizes (8): 

45 e a/a;=e sfmi^)^^ geom(^) 

where (9): 



so 



55 



is the usual structure from motion objective function that minimizes deviation from observed point feature positions, and 
P() is given in (4) above, and (10): 
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is the vector of structure and motion parameters which determine the Image of point / in frame j. The vector a contains 
all of the unknown structure and motion parameters, including the 3-D points p/. the time-dependent motion parameters 
my. and the global motion/calibration parameters nrig. The superscript T denotes a vector or matrix transpose. The 
weight Cjj in (9) describes the confidence in measurement L/,y, and is normally set to the inverse variance a,/ ^. Here, the 
can have a value proportional to the least amount of local texture indicated by the minimum eigenvalue of the local 
Hessian. 

[0043] The local Hessian H is given by: (1 1) 

2 

X ^ w^x ^ y 

^ i I y 1 ^ 
'x ' y ^w* y ^ 

Where w is the local window centered at (x, y) and (1^^, ly) Is the intensity gradient at pixel (x, y). If e^i^ ij 's the minimum 
eigenvalue at point / in frame then: (12) 

[0044] This is particularly important in the case of recovery of a face model because of the possible lack of texture on 
parts of the face, such as the cheeks and forehead areas. Using this metric for c,j minimizes the importance of points 
on these relatively untextured areas. To account for occlusions, is set to zero when the corresponding point is pre- 
dicted to be hidden. 
[0045] The other term in (8) is (13): 



which is the additional geometric constraints that reduces the deformation of the template or reference 3-D model. The 
quantities with the superscript 0 refer to the reference 3-D model that is to be deformed. /?, is the perpendicular distance 
of point Pi to the plane passing through its nearest neighbors, here three. In other words. /// is the best fit plane of the 
neighbor points of p,. and pxn, = d, is the equation of //,. then (14): 

a, is the weight associated to the preservation of local height, i.e. , to preserve curvature, and p/ is the weight associated 
with the preservation of the reference 3-D position. The weights can be made to vary from node to node, or made con- 
stant across all nodes. 

[0046] The Levenberg-Marquardt algorithm first forms the approximate Hessian matrix (15): 



where 8(^i) is a matrix which is zero everywhere except at the diagonal entries corresponding to the ith 3-D point. The 
weighted gradient vector is (16): 



H = 



Where 9^ ( 0 ... p'J 0 )^ . and (17): 



EP 0 907 144 A2 

=ai(hi-h°)n^+Pi(PrP'!) 



) 



from (14) and using the simplifying assumption that each node position is independent of its neighbors, although this is 
not strictly true. Here, e = u ,y - Ha J is the image plane error of point / in frame j. 

[0047] Given a current estir^iate of a. an increment 8a towards the local minimum is determined by solving (18). 



where X is a stabilizing factor which varies over time. A line^rf-sight constraint is also imposed on the recovered 3-D 
point with respect to the reference image. 

Generating Predicted Appearance 

[0048] It is relatively easy to render the model given the facets and vertices of a 3-D surface model, described in detail 
below e g the 3-D geometric constraints 221 of Figure 2. The object facets of the surface model are sorted in order of 
decreasing depth relative to the camera 1 1 0. and then rendered by texture-mapping the facete in the same decreasing 
depth order. The rendering technique can be any standard technique used in computer graphics. 
[0049] A 3-D model that is a good candidate for our proposed approach is the human face mode . «s structure is 
knowr! and using conventional stereo techniques are not very reliable because the human face usually has signrficant 
portions of relatively untextured regions. 

Mapping faces to a 3-D Computer Generated Face 

[0050] DECface is a system that facilitates the development of applications requiring a real-time lip-synchronized syn- 
thetic talkina head see U S Patent 5,657.426. issued to Waters on August 12, 1997. 

[0051 1 DECface has been built with a simple interface protocol to support the development of face-related applica- 
tions. The fundamental components of DECface are software speech synthesis, audio-file, and face 
[0052] Of particular importance to the present invention is the face modeling component. It involves texture-mapping 
offrontalviewfaceimages. synthetic or real, onto a correctly-shaped wireframe. .i^^io 9 n 

[0053] Topologies for facial synthesis are typically generated from explicit 3-D polygons. For simplicity, a s-mp^e 2-D 
Sepresentation of the full frontal view is constructed because, for the most part personal ^^^^^^^^^ n?j!s 200 
[0054] As shown in Figure 4. a wireframe model 400 is superimposed on a facial image. The model 400 .ndudes 200 
polygons of which 50 represent the mouth and an additional 20 represent the teeth. The jaw nodes are moved vertically 
as a function of displacement of the corners of the mouth. The lower teeth are displaced along wi h the lower jaw Eye- 
lids are created from a double set of nodes describing the upper lid. such that as they move, the hds close. 
[0055] The canonical representation is originally mapped onto the individual's image mostly by hand. This requires 
the careful placement of key nodes to certain locations, the corners of the lips and eyes, the placement of the chin and 
eyebrows, as well as the overall margins of the face. 

Mapping Faces using one input image 

[0056] AS mentioned in the previous section, mapping new faces to DECface involves texture-nnapping frontal view 
ace images (synthetic or real) onto a correctly-shaped wireframe. The original method to generate DECface with a ne« 
face is to manually adjust every node, which is a very tedious process. A "generic" separate f^'^^^^^^^l^^^ 
ogy and 3-D distribution is known is used as a reference during the process of moving each node within the new face 
image. This node-moving process is equivalent to the transfer of z information from the generic ^^^^ *° ♦^^^ '^^^ 
Methods to automate this process by using templates of facial features such as the eyes, mouth, and face pro« e have 
also been used. For a detailed description please see. EP application 98304034.6. •Automated Mapping of Facial 
image to Wireframe Topology", filed by Digital Equipment Corporation, inventors being Kang a';^ Watere. 
[0057] Because only one face input image is used, to generate the appropriate 3-D version of DECface. the canonical 
height distribution is preserved. This is. however, not always desirable, especially since many human faces Ijave signif- 
■intly different facial shapes. As a result, to preserve as much as possible the correct shape, we^^e three input 
ir-hoes. each showing a different pose of the face, with one showing the frontal face pose. It is possible, of course, to 
use more than three images to achieve the same goal. 
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Mapping faces using three input images 

[0058] In the preferred embodiment, three images of a face at different orientations are used. An image of a frontal 
pose is used as the reference image. As before, the camera parameters, intrinsic and extrinsic, are generally not known. 
5 For simplicity, one can assume that the aspect ratio is one, the image skew is zero, and the principal point is at the 
image center. The point correspondences between the generic face and the reference face has been done as in 
described above. This is the same as assuming that the reference shape of the model has been initialized. Note, how- 
ever, that the point correspondences across the image sequence are not known. 

[0059] The values a, and P/ in (13) are set to 0.25. As mentioned above, the feature track fine-tuning step involves 
10 using the spline-based tracker on the predicted appearance and actual image. However, because the prediction does 
not involve the background, only the predicted face image portion of the image is involved; the weights associated with 
the background are set to zero in the spline-based tracker. 

[0060] The method may fail when the change in the appearance of the object is too drastic from one frame to another 
in a sequence. In an 3-D face modeling application, rotations of up to about 15** between images are well tolerated. 
15 [0061 1 A variant of the method would involve the direct incorporation of tfie optic flow term into the objective function 
(8) to yield (19): 

20 where (20): 



i J> 1 

25 

with l/Uii) being the intensity (or color) at Uy on frame y, and y,y is the weight associated with the point Ufj, Note, that in 
this particular application of facial model recovery, the value of u,; is kept constant throughout because tine first frame 
is tiie reference frame. 

30 [0062] One problem with directly embedding this term in the structure from motion module is that the flow error term 
is local and thus unable to account for large motions. It would either require that the initial model pose be quite close to 
the true model pose, or the addition of a hierarchical scheme similar to that inrtplemented in the spline-based registration 
method. Otherwise, the method is likely to have better convergence properties when the tracking is performed outside 
the structure from motion loop. In the present implementation, while having the small perturbations of the model pose 

35 would be desirable from the computational point of view, although not from the accuracy point of view, this is not a 
requirement. 

[0063] In addition, using the flow error term directly may not be efficient from the computational point of view. This is 
because at every iteration and incremental step, a new predicted appearance has to be determined. This operation is 
rather computationally expensive, especially when the size of the projected model is large. Having the tracking module 
40 only loosely coupled with structijre from motion results in fewer number of iterations in computing the predicted object 
appearance. Rnally. there is the non-frivial question of assigning the weights y,y relative to tiie structure from motion and 
geometi-rc constraint related weights. 

[0064] Geometric constraints on the face deformation in other forms can also be used. An example would be to use 
the most dominant few deformation vectors based on Singular Value Decomposition (SVD) analysis of multiple training 
45 3-D faces. A similar approach would be to apply nodal analysis on the multiple training 3-D faces to extract common 
and permissible deformations in terms of nonrtgid modes. 

Summary 

so [0065] Described is an appearance-based structure from motion method that enables the direct extraction of 3-D 
models from a sequence of uncalibrated images. It is not necessary to precompute feature correspondences across the 
image sequence. The method dynamically determines the feature correspondences, estimates the structure and cam- 
era motion, and uses this information to predict the object appearance in order to refine the feature correspondences. 
[0066] It is understood that tiie above-described embodiments are simply illustrative of the principles of the invention. 

55 Various other modifications and changes may be made by those skilled in the art. which will embody the principles of 
the invention and fall within the scope thereof. 
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Claims 



1. A computerized method for extracting a three-dimensional configuration information from a sequence of two- 
dimensional images of an object, comprising the steps of: 

(a) registering each image in the sequence with a reference image to determine image features; 

(b) recovering structure and motion parameters from the image features using geometric constraints; 

(c) generating a predicted appearance for each image using the recovered structure and motion parameters; 

(d) registering each predicted appearance with the corresponding image; and 

10 repeating the recovering (b). generating (c) and registering (d) steps until a termination condition is reached. 

2. The method of claim 1 . wherein the registering is done using spline-based image registration. 

3. The method of claim 1 . wherein the geometric constraints are imposed directly on the 3-D wireframe model of the 
75 object. 

4. The method of claim l , wherein the object is a face. 

5. The method of claim 1 , wherein the sequence of images includes at least two images. 

20 

6. The method of claim 1 . wherein the repeating terminates when an average pixel value difference between each 
predicted appearance and each corresponding image is less than a predetermined threshold. 

7. The method of claim 1 , wherein camera parameters are generally unknown. 

25 

8. The method of claim 3. wherein the wireframe model is composed of triangular facets. 
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